import { Layout, Playground, Attributes } from 'lib/components'
import { Badge, Spacer, Button, Link, Avatar, useTheme } from 'components'
import NextLink from 'next/link'

export const meta = {
  title: '徽章 Badge',
  group: '数据展示',
}

## Badge / 徽章

显示一个需要注意的指标。

<Playground
  scope={{ Badge, Spacer }}
  desc="展示一个数字或一段文字。"
  code={`
<>
  <Badge>1</Badge> <Spacer y={.5} />
  <Badge>50</Badge> <Spacer y={.5} />
  <Badge>100</Badge> <Spacer y={.5} />
  <Badge>2020</Badge>
</>
`}
/>

<Playground
  title="类型"
  desc="以不同的色彩表达不同的状态。"
  scope={{ Badge, Spacer }}
  code={`
<>
  <Badge type="success">成功</Badge> <Spacer y={.5} />
  <Badge type="warning">警告</Badge> <Spacer y={.5} />
  <Badge type="error">错误</Badge> <Spacer y={.5} />
  <Badge type="secondary">次要的</Badge>
</>
`}
/>

<Playground
  title="Custom color"
  desc={
    <>
      了解更多颜色，请参考{' '}
      <NextLink href="/zh-cn/guide/colors">
        <Link color>色彩章节</Link>
      </NextLink>
      。
    </>
  }
  scope={{ Badge, Spacer, useTheme }}
  code={`
() => {
  const theme = useTheme()
  return (
    <>
      <Badge style={{ backgroundColor: theme.palette.successLight }}>淡色成功状态</Badge> <Spacer y={.5} />
      <Badge style={{ backgroundColor: theme.palette.successDark }}>深色成功状态</Badge> <Spacer y={.5} />
      <Badge style={{ backgroundColor: theme.palette.alert }}>警告</Badge> <Spacer y={.5} />
      <Badge style={{ backgroundColor: theme.palette.purple }}>紫色</Badge> <Spacer y={.5} />
      <Badge style={{ backgroundColor: theme.palette.violet }}>紫罗兰</Badge> <Spacer y={.5} />
      <Badge style={{ backgroundColor: theme.palette.cyanLighter, color: theme.palette.foreground }}>淡青色</Badge> <Spacer y={.5} />
    </>
  )
}
`}
/>

<Playground
  title="大小"
  desc="不同大小的徽章组件。"
  scope={{ Badge, Spacer }}
  code={`
<>
  <Badge size="mini">极小</Badge> <Spacer y={.5} />
  <Badge size="small">较小</Badge> <Spacer y={.5} />
  <Badge size="medium">中等</Badge> <Spacer y={.5} />
  <Badge size="large">最大</Badge>
</>
`}
/>

<Playground
  title="锚点"
  desc="将徽章固定在指定位置。"
  scope={{ Badge, Avatar, Spacer, Button, Link }}
  code={`
<>
  <Badge.Anchor>
    <Badge size="mini">10</Badge>
    <Avatar src="/images/avatar.png" />
  </Badge.Anchor>
  <Spacer inline x={1.5} />
  <Badge.Anchor placement="bottomRight">
    <Badge size="mini" type="success">10</Badge>
    <Avatar size={40} isSquare src="/images/avatar.png" />
  </Badge.Anchor>
  <Spacer inline x={1.5} />
  <Badge.Anchor>
    <Badge size="mini" type="warning">99+</Badge>
    <Button size="small" auto>按钮</Button>
  </Badge.Anchor>
  <Spacer inline x={1.5} />
  <Badge.Anchor>
    <Badge size="mini" type="error" dot />
    <Link target="_blank" href="https://github.com/geist-org/react/">组件库</Link>
  </Badge.Anchor>
  <Spacer inline x={1.5} />
  <Badge.Anchor>
    <Badge size="mini" type="error" dot style={{ padding: '7px' }} />
    <Link target="_blank" href="https://github.com/geist-org/react/">分享链接</Link>
  </Badge.Anchor>
</>
`}
/>

<Attributes edit="/pages/zh-cn/components/badge.mdx">
<Attributes.Title>Badge.Props</Attributes.Title>

| 属性     | 描述               | 类型             | 推荐值                          | 默认      |
| -------- | ------------------ | ---------------- | ------------------------------- | --------- |
| **type** | 徽章的类型         | `NormalTypes`    | [NormalTypes](#normaltypes)     | `default` |
| **size** | 徽章的大小         | `NormalSizes`    | [NormalSizes](#normalsizes)     | `medium`  |
| **dot**  | 忽略内容并显示圆点 | `boolean`        | -                               | `false`   |
| ...      | 原生属性           | `HTMLAttributes` | `'alt', 'id', 'className', ...` | -         |

<Attributes.Title>Badge.Anchor.Props</Attributes.Title>

| 属性          | 描述           | 类型              | 推荐值                              | 默认       |
| ------------- | -------------- | ----------------- | ----------------------------------- | ---------- |
| **placement** | 固定徽章的位置 | `AnchorPlacement` | [AnchorPlacement](#anchorplacement) | `topRight` |
| ...           | 原生属性       | `HTMLAttributes`  | `'alt', 'id', 'className', ...`     | -          |

<Attributes.Title>NormalTypes</Attributes.Title>

```ts
type NormalTypes = 'default' | 'secondary' | 'success' | 'warning' | 'error'
```

<Attributes.Title>NormalSizes</Attributes.Title>

```ts
type NormalSizes = 'medium' | 'mini' | 'small' | 'large'
```

<Attributes.Title>AnchorPlacement</Attributes.Title>

```ts
type AnchorPlacement = 'topLeft' | 'topRight' | 'bottomLeft' | 'bottomRight'
```

</Attributes>

export default ({ children }) => <Layout meta={meta}>{children}</Layout>
